<script lang="ts" setup>
import { useData } from 'vitepress';
import VPFlyout from './VPFlyout.vue';
import VPMenuLink from './VPMenuLink.vue';
import VPSwitchAppearance from './VPSwitchAppearance.vue';
import VPSocialLinks from './VPSocialLinks.vue';

const { site, theme } = useData();
</script>

<template>
    <VPFlyout class="VPNavBarExtra" label="extra navigation">
        <div v-if="theme.localeLinks" class="group">
            <p class="trans-title">{{ theme.localeLinks.text }}</p>

            <template v-for="locale in theme.localeLinks.items" :key="locale.link">
                <VPMenuLink :item="locale" />
            </template>
        </div>

        <div v-if="site.appearance" class="group">
            <div class="item appearance">
                <p class="label">Gitee</p>
                <div class="appearance-action">
                    <a href="https://gitee.com/ubml/farris-vue" target="_blank" class="address" title="前往Farris Vue"><img src="/assets/gitee.svg" /></a>
                </div>
            </div>
            <div class="item appearance">
                <p class="label">Appearance</p>
                <div class="appearance-action">
                    <VPSwitchAppearance />
                </div>
            </div>
        </div>

        <div v-if="theme.socialLinks" class="group">
            <div class="item social-links">
                <VPSocialLinks class="social-links-list" :links="theme.socialLinks" />
            </div>
        </div>
    </VPFlyout>
</template>

<style scoped>
.address img {
    margin-right: 8px;
    display: block;
    width: 18px;
}
.VPNavBarExtra {
    display: none;
    margin-right: -12px;
}

@media (min-width: 768px) {
    .VPNavBarExtra {
        display: block;
    }
}

@media (min-width: 1280px) {
    .VPNavBarExtra {
        display: none;
    }
}

.trans-title {
    padding: 0 24px 0 12px;
    line-height: 32px;
    font-size: 14px;
    font-weight: 700;
    color: var(--vp-c-text-1);
}

.item.appearance,
.item.social-links {
    display: flex;
    align-items: center;
    padding: 0 12px;
}

.item.appearance {
    min-width: 176px;
}

.appearance-action {
    margin-right: -2px;
}

.social-links-list {
    margin: -4px -8px;
}
</style>
